AMENDMENT 



In the Claims 

Please amend claims 1-3, 5, 6, 15, 16. 25, 26, and 34 as follows. 

1 . (Currently Amended) A method comprising: 

starting execution of a basic input output system (BIOS), the BIOS having 
including a plurality of fimriware modules; 

detemnining finnware resources required by each of the plurality of fimriware 
modules to operate , the fimnware resources required, if any, for a given firmware 
module provided bv one or more other firmware modules : 

scheduling modules of the plurality of firmware modules for execution in 
consideration of the required firmware rooouroo resources that are determined; and 

dispatching the scheduled modules for execution. 

2. (Cun^ently Amended) The method of claim 1, further compr l G i ng i nit i al i z i ng a 
memory of tho p l atform after tho schodu l od modules aro d i opatchod wherein the 
plurality of firmware modules are dispatched and executed in a pre-memorv execution 
environment prior to availability of system memory for a platform on which the BIOS is 
installed . 

3. (Currently Amended) The method of claim 1, further comprising calling a second 
module of the plurality of fimiware modules for execution during execution of another a 
first module of the plurality of firmware modules , the second module being called bv a 
corresponding call instruction in the first module . 
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4. (Previously Presented) The method of claim 3, wherein calling a module of the 
plurality of fimiware modules further comprises: 

saving a retum address; 

detemiining a physical address of the module; 

executing an instmction stored at the physical address of the module; and 
executing an instruction stored at the saved return address when the module 
execution is complete. 

5. (Currently Amended) The method of claim 4, wherein detemiining the physical 
address of the second module comprises looking up the physical address in an import 
table of the oth e r first module. 

6. (Currently Amended) The method of claim 1 , wherein a module of the plurality of 
firmware modules comprises: 

a globally unique identifier (GUID) to identify the module; 
a resource list to store information identifying firmware resources needed by the 
module to operate; 

an import table to store physical addresses of a set of modules of the plurality of 
fimiware modules that the module may call during execution; 

a service that when executed performs a predetermined function; 

an export table to store a value corresponding to a physical address of the 
service; and 

an interface operatively coupled to the GUID, resource list, the service, the 
import table, and the export table, wherein the interface is addressable by a calling 
agent via the GUID to provide the calling agent access to the resource list, the service, 
the import table, and the export table. 
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7. (Original) The method of claim 6, wherein the value stored by the export table is 
an offset from a start address of the module. 

8. (Previously Presented) The method of claim 6, wherein the import table stores 
GUIDs of the set of modules of the plurality of fimiware modules. 

9. (Previously Presented) The method of claim 1 , further comprising: 
starting execution of a first module of the plurality of fimiware modules; 
detemiining whether the first module is chainable with another module of the 

plurality of fimiware modules; 

determining whether a hardware component associated with the first module is 
present in the platform if the first module is chainable; 

completing execution of the first module if the hardware component associated 
with the first module is present in the platform; and 

starting execution of a second module of the plurality of fimiware modules 
without completing execution of the first module if the hardware component associated 
with the first module is not present in the platfomi. 

10. (Original) The method of claim 9, wherein the first module includes a data 
structure to store a physical address of the second module. 

1 1 . (Previously Presented) The method of claim 9, further comprising: 
determining whether a hardware component associated with the second module 

of the plurality of firmware modules is present in the platform if the first module is 
chainable; 

completing execution of the second module if the hardware component 
associated with the second module is present in the platfomi; 
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determining whether a third module is chained to the second module if the 
hardware component associated with the second module is not present in the platform; 
and 

executing the third module of the plurality of firmware modules without 
completing execution of the second module if third module is chained to the second 
module. 

12. (Original) The method of claim 11, wherein completing execution of the second 
module further comprises returning to a calling agent that called the first module, 

1 3. (Previously Presented) The method of claim 1 , further comprising: 

executing a call made by a calling agent to a first module of the plurality of 
firmware modules, wherein the call is one of a set of calls, each call of the set of calls 
being associated with a module of a set of modules of the plurality of firmware modules, 
the associations being dependent on a configuration of the platform; 

starling execution of the first module of the plurality of firmware modules in 
response to the call; 

determining which module of the set of modules is associated with the call; and 

starting execution of the module associated with the call. 

14. (Original) The method of claim 13, further comprising retuming to the calling 
agent when execution of the module associated with the call is complete. 

15. (Currently Amended) A machine readable medium containing instructions that 
when executed by a machine, cause the machine to perform operations comprising: 

starting execution of a basic input output system (BIOS), the BIOS hav i ng 
including a plurality of firmware modules; 
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determining finmware resources required by each of the plurality of finnware 
modules to operate , the firmware resources recuired. if any, for a given firmware 
module orovided bv one or more other finmware modules : 

scheduling modules of the plurality of firmware modules for execution In 
consideration of the required firmware rocouroQ resources that are determined; and 

dispatching the scheduled modules for execution. 

16. (Currently Amended) The machine readable medium of claim 15, wherein the 
machine comprises a platfomi includinc a orocessor on which the instructions are 
executed and system memory, further comprising instructions that when executed by 
the machine cause the machine to perfomri an operation of initializing [[a]] the system 
memory of the maohino platform after the scheduled modules are dispatched. 

17. (Preyiously Presented) The machine readable medium of claim 15, further 
comprising instructions that when executed by the machine cause the machine to 
perform an operation of calling a module of the plurality of firmware modules for 
execution during execution of another module of the plurality of finnware modules. 

18. (Previously Presented) The machine readable medium of claim 17, wherein 
calling a module of the plurality of finnware modules further comprises instructions that 
when executed by the machine cause the machine to perform operations comprising: 

saying a return address; 

determining a physical address of the module; 

executing an instruction stored at the physical address of the module; and 
executing an instruction stored at the saved return address when the module 
execution is complete. 
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19. (Previously Presented) The machine readable medium of claim 15, wherein a 
module of the plurality of firmware modules comprises: 

a globally unique identifier (GUID) to identify the module; 
a resource list to store infomiation identifying resources needed by the module to 
operate; 

an import table to store physical addresses of a set of modules of the plurality of 
finnware modules that the module may call during execution; 

a service that when executed performs a predetennined function; 

an export table to store a value corresponding to a physical address of the 
service; and 

an interface operatively coupled to the GUID, resource list, the service, the 
import table, and the export table, wherein the interface is addressable by a calling 
agent via the GUID to provide the calling agent access to the resource list, the service, 
the import table, and the export table. 

20. (Previously Presented) The machine readable medium of claim 15, further 
comprising instructions that when executed by the machine cause the machine to 
perfomi operations comprising 

starting execution of a first module of the plurality of fimnware modules; 

detennining whether the first module is a chainable with another module of the 
plurality of firmware modules; 

detennining whether a hardware component associated with the first module is 
present in the machine if the first module is chainable; 

completing execution of the first module if the hardware component associated 
with the first module is present in the machine; and 
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starting execution of a second module of the plurality of fimnware modules 
without completing execution of the first module if the hardware component associated 
with the first module is not present in the machine. 

21. (Previously Presented) The machine readable medium of claim 20, further 
comprising instructions that when executed by the machine cause the machine to 
perfomi operations comprising: 

detennining whether a hardware component associated with the second module 
of the plurality of firmware modules is present in the machine if the first module is 
chainable; 

completing execution of the second module if the hardware component 
associated with the second module is present in the machine; 

detennining whether a third module is chained to the second module if the 
hardware component associated with the second module is not present in the machine; 
and 

executing the third module of the plurality of finnware modules without 
completing execution of the second module if third module is chained to the second 
module. 

22. (Original) The machine readable medium of claim 21, wherein completing 
execution of the second module further comprising instructions that when executed by 
the machine cause the machine to perform an operation of returning to a calling agent 
that called the first module. 

23. (Previously Presented) The machine readable medium of claim 15, further 
comprising instructions that when executed by the machine cause the machine to 
perfomi operations comprising: 
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executing a call made by a calling agent to a first module of the plurality of 
firmware modules, wherein the call Is one of a set of calls, each call of the set of calls 
being associated with a module of a set of modules of the plurality of firmware modules, 
the associations being dependent on a configuration of the machine; 

starting execution of the first module of the plurality of fimiware modules in 
response to the call; 

detemiining which module of the set of modules is associated with the call; and 

starting execution of the module associated with the call, 

24. (Original) The machine readable medium of claim 23, further comprising 
instructions that when executed by the machine cause the machine to perform an 
operation of returning to the calling agent when execution of the module associated with 
the call is complete. 

25. (Currently Amended) A system, comprising: 
a plurality of hardware components[[:]] ; 

a first memory device to store a BIOS, the BIOS hav i ng including a plurality of 
fimnware modules, the BIOS further including[[;]] ^ 

means for determining firmware resources required by each of the plurality of 
firmware modules to operate, the fimriware resources required, if any, for a given 
firmware module provided bv one or more other firmware modules: 

means for scheduling execution of modules of the plurality of fimiware 
modules[[,]] ; [[and]] 

means for dispatching scheduled modules for execution; and 

a orocessor on which the fimiware modules are executed, coupled to the plurality 
of hardware components and the first memory device. 
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26. (Currently Amended) The system of claim 25, wherein the BIOS further 
comprises means for initializing [[a]] system memory of the system after the scheduled 
modules are dispatched. 

27. (Previously Presented) The system of claim 25, wherein the BIOS further 
comprises means for calling a module of the plurality of firmware modules for execution 
during execution of another module of the plurality of firmware modules. 

28. (Previously Presented) The system of claim 27, wherein the means for calling a 
module of the plurality of firmware modules further comprises: 

means for saving a return address; 

means for determining a physical address of the module; 

means for executing an instruction stored at the physical address of the module; 

and 

means for executing an instruction stored at the saved retum address when the 
module execution is complete. 

29. (Previously Presented) The system of claim 25, wherein a module of the plurality 
of finnware modules comprises: 

a globally unique identifier (QUID) to identify the module; 
a resource list to store information identifying resources needed by the module to 
operate; 

an import table to store physical addresses of a set of modules of the plurality of 
finnware modules that the module may call during execution; 

a service that when executed performs a predetemiined function; 

an export table to store a value corresponding to a physical address of the 
service; and 
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an interface operatively coupled to the GUID, resource list, the service, the 
import table, and the export table, wherein the interface is addressable by a calling 
agent via the GUID to provide the calling agent access to the resource list, the service, 
the import table, and the export table. 

30. (Previously Presented) The system of claim 25, wherein the BIOS further 
comprises: 

means for starting execution of a first module of the plurality of firmware 
modules; 

means for detenmining whether the first module is a chainable with another 
module of the plurality of firmware modules; 

means for determining whether a hardware component of the plurality of 
hardware components that is associated with the first module is present in the system if 
the first module is chainable; 

means for completing execution of the first module if the hardware component 
associated with the first module is present in the system; and 

means for starting execution of a second module of the plurality of firmware 
modules without completing execution of the first module if the hardware component 
associated with the first module is not present in the system. 

31. (Previously Presented) The system of claim 30, wherein the BIOS further 
comprises: 

means for determining whether a hardware component associated with the 
second module of the plurality of fimiware modules is present in the system if the first 
module is chainable; 

means for completing execution of the second module if the hardware 
component associated with the second module is present in the system; 

42P9 143 11 Examiner: Chen, Tse W. 

Ser. No. 10/073,495 Art Unit: 2116 



means for determining whether a third module is chained to the second module if 
the hardware component associated with the second module is not present in the 
system; and 

means for executing the third module of the plurality of fimiware modules without 
completing execution of the second module if third module is chained to the second 
module. 

32. (Original) The system of claim 31 , wherein the means for completing execution of 
the second module further comprises means for returning to a calling agent that called 
the first module. 

33. (Previously Presented) The system of claim 28, wherein the BIOS further 
comprises: 

means for executing a call made by a calling agent to a first module of the 
plurality of firmware modules, wherein the call is one of a set of calls, each call of the 
set of calls being associated with a module of a set of modules of the plurality of 
firmware modules, the associations being dependent on a configuration of the system; 

means for starting execution of the first module of the plurality of firmware 
modules in response to the call; 

means for determining which module of the set of modules is associated with the 
call; and 

means for starting execution of the module associated with the call. 

34. (Currently Amended) A system, comprising: 
a plurality of hardware components; 

a first memory device to store a BIOS, the BIOS comprising: 
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a plurality of firmware modules, each module of the plurality of firmware 
modules to provide at least one service, at least two modules providing an inter- 
module interface to enable each of said at least two modules to call a service 
provided by another module; 

a core operatively coupled to the plurality of firmware modules, wherein 
the core, upon operation, selects for execution a set of modules from the plurality 
of firmware modules to be executed in a pre-memorv execution environment 
prior to the initialization and availabilitv of svstem memorv : 
a processor coupled to the plurality of hardware components and the first 
memory device. 

35. (Previously Presented) The system of claim 34, wherein during execution of a 
first module of the plurality of firmware modules, the first module to selectively call a 
second module of the plurality of finnware modules for execution. 

36. (Original) The system of claim 35, wherein the first module comprises an import 
table to store a physical address of the second module, the first module further to store 
a return address in a register of the processor in calling the second module. 

37. (Previously Presented) The system of claim 34, wherein a module of the plurality 
of firmware modules comprises: 

a globally unique identifier (QUID) to identify the module; 
a resource list to store information identifying resources needed by the module to 
operate; 

an import table to store physical addresses of a set of modules of the plurality of 
firmware modules that the module may call during execution; 

a service that when executed performs a predetemiined function; 
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an export table to store a value corresponding to a physical address of the 
service; and 

an interface operatively coupled to the GUID, resource list, the service, the 
import table, and the export table, wherein the Interface is addressable by a calling 
agent via the GUID to provide the calling agent access to the resource list, the service, 
the import table, and the export table. 

38. (Previously Presented) The system of claim 34, wherein a set of modules of the 
plurality of modules have identical global unique identifiers (GUIDs). 

39. (Original) The system of claim 38, wherein during execution of a first module of 
the set of modules, the processor to complete execution of the first module when a first 
hardware component Is associated with the first module is present in the system, the 
first hardware component being one of the plurality of hardware components. 

40. (Original) The system of claim 39, wherein the first module to call a second 
module of the set of modules when the first hardware component is not present in the 
system. 

41 . (Previously Presented) The system of claim 34, wherein during execution of a 
first module of the plurality of fimiware modules, the first module to call a second 
module of the plurality of firmware modules to perform a service, the second module to 
call a third module as a function of a configuration of the system, the third module being 
one of a set of modules of the plurality of firmware modules each being associated with 
a different hardware component of the plurality of hardware components that provide 
the service called by the first module. 
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